package com.hy;

/**
 * Created With IntelliJ IDEA.
 * Descriptions:验证回文串
 *
 * 如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后，短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。
 * 字母和数字都属于字母数字字符。
 * 给你一个字符串 s，如果它是 回文串 ，返回 true ；否则，返回 false 。
 *
 * User:Mr.Du
 * Date:2024/8/17
 * Time:15:39
 */
public class IsPalindrome {
    public boolean isPalindrome(String s) {
        s = s.toLowerCase().trim();
        if(s.length() == 0) return true;
        int l = 0, r = s.length() - 1;
        while(l < r){
            if(!isP(s.charAt(l))) l++;
            else if(!isP(s.charAt(r))) r--;
            else if(s.charAt(r) == s.charAt(l)){
                r--;
                l++;
            }
            else return false;
        }
        return true;
    }

    public boolean isP(char c){
        return Character.isLowerCase(c) || Character.isUpperCase(c)
                || Character.isDigit(c);
    }
}
